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Method, modules and program modules for synchronization 



Description 
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Field of the Invention 

The present invention relates to a method for synchronization of a first and at 
least a second module, each having a clock generator. 



Background of the Invention 

In the field of telecommunication and of computer technology, the assemblies of 
an appliance that are needed for operation can frequently not be disposed on 

15 one electronic printed circuit board, but have to be distributed over a plurality of 
separate modules each having one or more printed circuit boards. In the case of 
telecommunication systems, in particular, redundant modules are also used for 
fail-safe reasons. So that the modules operate synchronously, the modules are 
supplied with a central timing signal, also known as "clock signal". Such a central 

20 clock signal is generated by a central clock generator and transmitted to the 

modules. Provided for the transmission is, for example, a clock channel in a bus 
to which the modules are connected. The modules operate either directly with the 
clock signal picked up from the bus or synchronize a separate, local clock 
generator, present on the respective module, to the central clock signal. In the 

25 latter case the local clock generators each generate local clock signals that are 
slightly phase-shifted in relation to the central clock signal, which shift is due to 
the transit time of the central clock signal on the bus. 
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In the case of high-precision appliances operating at high clock frequency, for 
example in the case of so-called cross connects in the SDH transmission technique 
(SDH = synchronous digital hierarchy), this phase shift already has an interfering 
effect on the precision of the appliance. The modules of an appliance then no 
5 longer operate with adequate synchronism and, for example, data is overtaken in 
the messages that the modules exchange with one another via the 
abovementioned bus. 

Even if software modules are to interact under real-time conditions that are 
10 managed in each case by separate operating systems each having a local clock 
generator, a disturbing asynchronism may occur in the distribution of a central 
clock signal to the respective operating systems as a result of the transit time of 
the central clock signal. 

15 The object of the invention is therefore to synchronize with high precision modules 
that each have a local clock generator. 

Summary of the Invention 

20 This object is achieved by a method for synchronization of a first and at least a 

second module, each having a clock generator, the method comprising the steps 
of 

transmitting by the first module, a first clock signal generated by its clock 
generator to the at least one second module, 
25 - synchronizing the clock generator of the at least one second module with the 
first clock signal, 

transmitting by the at least one second module a second clock signal 
generated by the clock generator that is synchronized with the first clock 
signal to the first module, 
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determining by the first module, a (first) time difference value between the 
first clock signal and the at least one second clock signal, which time 
difference value is essentially due to the transmission time of the first and the 
at least one second clock signal between the first, and the at least one 
5 second module, 

transmitting by the first module, an item of information about the (first) time 
difference value to the at least one second module and 

adjusting the clock generator of the at least one second module on the basis 
of the information about the (first) time difference value. 

10 

In another aspect of the invention, this object is achieved by a (first) module 
having a first clock generator for synchronization with at least one second module 
having a second clock generator, comprising 

transmitting means for transmitting a first clock signal generated by the first 
1 5 clock generator to the at least one second module 

receiving means for receiving at least one second clock signal generated by 
the respective second clock generator and synchronized with the first clock 
signal and transmitted by the at least one second module, and 
generating means for forming a (first) time difference value between the first 
20 clock signal and the at least one second clock signal, which time difference 

value is essentially due to the transmission time of the first and of the at least 
one second clock signal between the first, and the at least one second 
module, 

wherein the transmitting means are designed for sending an item of information 
25 about the (first) time difference value to the at least one second module. 



In another aspect of the invention, this object is achieved by a (second) module 
having a clock generator for synchronization with at least one first module, 
comprising 
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receiving means for receiving a first clock signal sent by the first module, 
synchronizing means for synchronizing its clock generator on the basis of the 
first clock signal, and 

transmitting means for sending a second clock signal synchronized with the 
5 first clock signal to the first module, 

wherein the receiving means are designed for receiving an item of information 
sent by the first module about a (first) time difference value formed from the first 
clock signal and the second clock signal, which time difference value is essentially 
due to the transmission time of the first and of the at least one second clock signal 
10 between the first, and the at least one second module, and wherein the 

synchronizing means are designed for adjusting the clock generator on the basis 
of the information about the (first) time difference value. 



In jet another aspect of the invention, the object is achieved by a master program 
1 5 module for a (first) module having a first clock generator for synchronization with 
at least one second module having a second clock generator, wherein the master 
program module contains a program code that can be run by a control means of 
the first module, the master program module further comprising 

transmitting means for sending a first clock signal generated by the first 
20 clock generator to the at least one second module, 

receiving means for receiving at least one second clock signal generated by 
the second clock generator that is synchronized with the first clock signal 
and sent by the at least one second module, and 

generating means for forming a (first) time difference value between first 
25 clock signal and the at least one second clock signal, which time difference 

value is essentially due to the transmission time of the first and of the at least 
one second clock generator between the first, and the at least one second 
module, 
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wherein the transmitting means are designed for sending an item of information 
about the (first) time difference value to the at least one second module. 

In jet another aspect of the invention, the object is achieved by a slave program 
5 module for a (second) module having a clock generator for synchronization with 
at least one first module, wherein the slave program module contains a program 
code that can be run by a control means of the second module, the slave 
program module further comprising 

receiving means for receiving a first clock signal sent by the first module, 
10 - synchronizing means for synchronizing the clock generator on the basis of 
the first clock signal, and 

transmitting means for sending a second clock signal synchronized with the 
first clock signal to the first module, 
wherein the receiving means are designed to receive an item of information 
1 5 transmitted by the first module about a (first) time difference value formed from 
the first clock signal and the second clock signal, which time difference value is 
essentially due to the transmission time of the first and of the at least one second 
clock signal between the first, and the at least one second module, and wherein 
the synchronizing means are designed to adjust the clock generator on the basis 
20 of the information about the (first) time difference value. 

In jet another aspect of the invention, the object is achieved by a device, in 
particular a telecommunication device, containing at least one first and at least 
one second module, each having a clock generator, wherein the at least one first 
25 module comprises 

transmitting means for transmitting a first clock signal generated by the first 

clock generator to the at least one second module. 
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receiving means for receiving at least one second clock signal generated by 
the respective second clock generator and synchronized with the first clock 
signal and transmitted by the at least one second module, and 
generating means for forming a (first) time difference value between the first 
5 clock signal and the at least one second clock signal, which time difference 

value is essentially due to the transmission time of the first and of the at least 
one second clock signal between the first and the at least one second 
module, 

wherein the transmitting means are designed for sending an item of information 
1 0 about the (first) time difference value to the at least one second module and 

wherein the at least one second module comprises 

receiving means for receiving a first clock signal sent by the first module, 
synchronizing means for synchronizing its clock generator on the basis of the 
first clock signal, and 

15 - transmitting means for sending a second clock signal synchronized with the 
first clock signal to the first module, 
wherein the receiving means are designed for receiving an item of information 
sent by the first module about a (first) time difference value formed from the first 
clock signal and the second clock signal, which time difference value is essentially 

20 due to the transmission time of the first and of the at least one second clock signal 
between the first and the at least one second module, and wherein the 
synchronizing means are designed for adjusting the clock generator on the basis 
of the information about the (first) time difference value. 

25 in this connection, the invention is based on the idea that a first module, referred 
to for simplicity as master module transmits a "master clock signal" generated by 
its clock generator to a module, referred to below as slave module for simplicity, 
and possibly to further slave modules. The slave modules then synchronize their 
respective clock generators to the master clock signal and transmit "slave clock 
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signals" generated by the now synchronized clock generators to the master 
module. The master module consequently receives a feedback for its 
synchronization. The master module then determines a time difference value 
between the master clock signal and the respective slave clock signal. This time 
5 difference is essentially due to the signal transit time necessary for the 

transmission of the master clock signal to the respective slave module and to the 
signal transit time needed for the transmission of the respective slave clock signal 
from the respective slave module to the master module. Normally, both signal 
transit times are equally long because of the symmetrical transmission paths 

1 0 between master module and slave module, with the result that the respective time 
difference value represents roughly half the signal transit time. The master module 
then transmits items of information about the respective time difference values to 
the slave module or slave modules, which adjust their clock generator on the 
basis of these items of information. The phase differences between master clock 

1 5 signal and the slave clock signals that are due to the respective signal transit times 
of the master clock signal to the slave modules are consequently reduced to an 
extent that is no longer troublesome and, under optimum conditions, are 
completely eliminated, with the result that the master module and the slave 
modules are optimally synchronized with one another. 

20 

Further advantageous refinements of the invention emerge from the dependent 
claims. 

In a preferred embodiment of the invention, either the master module or the slave 
25 modules halves/half the respective time difference value to determine the signal 
transit time and, consequently, the respective phase difference between master 
clock signal and slave clock signal to be corrected. If equally long signal transit 
times between master module and slave module are not involved, for example 
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because of different transmission paths, more elaborate algorithms can be used 
to determine the respective phase difference to be corrected. 

The master module may transmit the master clock signal continuously or, 
5 alternatively, only at predetermined time instants to the slave modules, for 

example in a cyclically recurring manner, only once, for example, in connection 
with a start synchronization procedure, or at irregular intervals, for example in 
times of low load on the master module and/or on the slave modules. 

10 In a further variant of the invention, the slave modules repeatedly transmit their 
respective slave clock signals to the master module, with the result that the latter 
can determine time difference values between the master clock signal and the 
respective slave clock signal and is thus able to monitor the synchronous 
operation of the slave modules with the master module. If a slave clock signal of 

15 a slave module is asynchronous with the master clock signal, the master module 
can again send a correction value to the respective slave module to adjust it$> 
respective clock generator. 

Expediently, the master module repeatedly transmits the master clock signal to the 
20 slave modules again so that the latter are able to determine, in one variant of the 
invention, time difference values between their respective slave clock signal and 
the master clock signal. This then results in various possibilities: 

The slave modules transmit the respective time difference values to the master 
25 module so that the latter can monitor the success of a synchronization procedure 
or can determine deviations possibly occurring during operation between master 
clock signal and the respective slave clock signals. The master module can then 
optionally start the above-described synchronization procedure again to 
synchronize the slave clock signals. 
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The slave modules can, however, also adjust their respective clock generators on 
their own initiative on the basis of the time difference values they have 
determined. 

The invention is explained below on the basis of exemplary embodiments with the 
aid of the figures. In the figures: 



Figure 1 shows a sequence of a synchronization according to the invention 

10 on the basis of diagrammatically shown modules MODI and 

MOD2 according to the invention, 
Figure 2 shows monitoring of the synchronization and a resynchronization 

subsequent to the synchronization in Figure 1 , 
Figure 3 shows a supplementary or alternative solution to Figure 2, that is to 
15 say monitoring of the synchronization and a resynchronization, 

likewise subsequent to the synchronization in Figure 1 , 
Figure 4 shows an arrangement for performing the method according to the 
invention. 



20 Detailed Description of the Invention 



Figure 1 shows a sequence of a synchronization according to the invention on the 
basis of diagrammatically shown modules MODI and MOD2 according to the 
invention. To clarify the synchronization sequence, the modules MODI and 
25 MOD2 are each shown in duplicate. The modules MODI and MOD2 are, for 
example, electronic printed circuit boards of a computer system or of a 
telecommunication junction, for example a SDH cross connect (SDH = 
synchronous digital hierarchy). The modules MODI and MOD2 are 
interconnected via a bus, which is not shown and on which the modules MODI 
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and MOD2 can send one another items of information. The transmitting and 
receiving modules necessary for this purpose are explained in greater detail in 
Figure 4. The modules MODI and MOD2 may also be software modules that 
each synchronize, for example, a local operating system. 

5 

A clock generator GEN1 and a logic component CP1 are shown in the module 
MODI and a clock generator GEN2 and a logic component CP2 in the module 
MOD2. The clock generators GEN1 and GEN2 each contain, for example, a 
quartz oscillator for generating a basic clock signal and a downstream electronic 

10 system, for example having a resettable counter, for generating an initial clock 
signal from the basic clock signal. Such circuits are known per se. The clock 
generator GEN1 generates, in this way, a clock signal TS1 and the clock 
generator GEN2 generates a clock signal TS2. The logic components CP1 and 
CP2 each comprise a comparator assembly for determining a phase difference 

1 5 between two clock signals and a generating assembly for forming a correction 
value with which the clock generator GEN2 can be adjusted. The logic 
components CP1 and CP2 may, for example, be signal processors or integrated 
circuits. The modules MODI and MOD2 may also comprise further functional 
assemblies, for example transmitters and/or receiving assemblies for transmitting 

20 and receiving user data telegrams, for example from SDH containers. 

Furthermore, the modules MODI and MOD2 and their functional components 
may be implemented as a whole by a processor that has a built-in clock 
generator and runs a program code of program modules according to the 
invention. 

25 

At the beginning of synchronization, the module MODI transmits the clock signal 
TS1 generated by its clock generator GEN1 to the module MOD2. The latter 
synchronizes its clock generator GEN2 with the clock signal TS1 . Because, 
however, a certain transmission time is necessary for the transmission of the clock 
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signal TS1 from the module MODI to the module MOD2 and, in addition, the 
operation of synchronizing the clock generator GEN2 also requires a certain 
processing time, the clock signal TS2DEL now generated by the clock generator 
GEN2 has a phase difference with respect to the clock signal TS1 . 

5 

The module MOD2 transmits the clock signal TS2DEL to the module MODI . 
Transmission time is likewise needed for this purpose. The module MODI 
determines a time difference value DIF1 between the clock signal TS1 and the 
clock signal TS2DEL it receives. The time difference value DIF1 is essentially due 

10 to the transmission time of the clock signal TS1 from the module MODI to the 
module MOD2 and the transmission time of the clock signal TS2DEL from the 
module MOD2 to the module MODI . Since the transmission paths between the 
modules MODI and MOD2 are equally long in the present case, the logic 
component CP1 halves the time difference value DIF1 and forms an item of 

15 correction information COR. The module MODI then transmits the correction 
information CORto the module MOD2, which adjusts its clock generator GEN2 
with the correction information COR. The clock generator GEN2 then generates a 
clock signal TS20PT that is synchronous with the clock signal TS1 . If the 
transmission paths between the modules MODI and MOD2 are not equally long, 

20 the logic component CP1 may also use other, more complex algorithms to form 
the correction value COR1 . 

The correction information CORmay contain, for example, a digitally encoded 
transmitted starting value or a resettable counter contained in the clock generator 
25 GEN2. It is also possible that the module MODI corrects the clock signal TS1 
forward in phase by the halved time difference value DIF1 between the clock 
signal TS1 and the clock signal TS2DEL and transmits the clock signal TS1 
"advanced" in this way as correction information CORto the module MOD2. 
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Furthermore, the module MODI may transmit the time difference value DIF1 
between the clock signal TS1 and the clock signal TS2DEL also in unprocessed 
form, that is to say as correction information CORto the module MOD2 without 
the halving described above. The module MOD2 then halves the time difference 
5 value DIF1 and thus adjusts its clock generator GEN2. Furthermore, the module 
MOD2 may incorporate, for example, also an offset value in the correction 
information COR. Such an offset value may represent, for example, the time that 
the clock generator GEN2 requires for the adjustment operation or that the 
module MOD2 needs to receive and read in the correction value COR1 . 

10 

Let the sequence shown in Figure 2 be preceded by the synchronization shown on 
the basis of Figure 1 . The clock generators GEN1 and GEN2 generate clock 
signals TS1 and TS2, respectively, that are synchronous under optimum 
conditions, for example in the case of interference-free clock generators GEN1 

15 and GEN2 operating in exactly the same way. The module MODI transmits the 
clock signal TS1 to the logic component CP2 of the module MOD2. Furthermore, 
the logic component CP2 receives the clock signal TS2 from the clock generator 
GEN2. From the clock signal TS1 delayed by the transmission from the module 
MODI and the local clock signal TS2, the logic component CP2 forms a time 

20 difference value DIF2 that, given synchronous clock signals TS1 and TS2, are 
equal to half the time difference value DIF1 . 

The module MOD2 transmits the time difference value DIF2 to the module MODI 
so that the latter can detect whether the clock signal TS2 is synchronous with the 
25 clock signal TS1 . If this is not the case, the module MODI may initialize the 

synchronization operation shown on the basis of Figure 1 again and/or signal the 
interference to a coordinating control for the modules MODI and MOD2. 



• # 

13 



In the present case, the logic component CP2 forms a correction value COR2 
from the time difference value DIF2 and the time difference value DIF1 previously 
received and stored by it. In this connection, the logic component CP2 subtracts, 
for example, from the time difference value DIF2 half the time difference value 
5 DIF1 . To form the correction value COR2, the logic component CP2 may also 
take into account further correction factors, for example a time that is needed to 
adjust the clock generator GEN2. The logic component CP2 supplies the 
correction value COR2 to the clock generator GEN2, which then adjusts itself 
again and, consequently, generates a clock signal TS20PTthat is synchronous 
1 0 with the clock signal TS1 . 

Let the sequence shown in Figure 3 also be preceded by the synchronization 
shown on the basis of Figure 1 . However, in Figure 3, the clock signal TS2DEL 
generated by the clock generator GEN2 is no longer precisely synchronous with 

15 the clock signal TS1 since, for example, the module MOD2 had no power supply 
for a short time. The module MOD2 transmits the clock signal TS2DEL to the 
module MODI . The clock signal TS2DEL arrives with a time shift due to the 
transmission. Given symmetrical transmission paths, said shift is equal, as 
explained on the basis of Figure 1 , to half the time difference value DF1 . The 

20 module MODI therefore first corrects the received time signal TS2DEL by half the 
time difference value DIF1 . Furthermore, the module MODI determines a time 
difference value DIF3 between the corrected clock signal TS2DEL and the clock 
signal TS1. The module MODI then sends an item of correction information 
COR2(DIF3) based on the time difference value DIF3 to the module MOD2 so 

25 that the latter can adjust its clock generator GEN2. The clock generator GEN2 
then again generates a clock signal TS20PT that is synchronous with the clock 
signal TS1 . 
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As shown on the basis of Figures 2 and 3, the module MOD2 may also be 
repeatedly resynchronized during continuous operation so that phase deviations 
between the clock signals TS1 and TS2 that may creep in during operation are 
eliminated again. 

5 

In addition to the module MOD2, further modules, not shown, can also be 
synchronized by the module MODI in the manner explained. Furthermore, it is 
possible that the module MOD2 also synchronizes a module depending on it 
since the module MOD2 is, as explained, very precisely synchronized with the 
10 module MODI . Not only "parallel circuits" can therefore be formed with a 

synchronizing module and a plurality of modules synchronized by it, but also 
cascaded arrangements. 

Figure 4 shows the modules MODI and MOD2 known from Figure 1 and a 
15 further module MOD3 in which a control module CPU3, for example a signal 
processor, fulfils the functions of a clock generator (GEN1 or GEN2) and the 
functions of the logic component (CP! , CP2) triggering the clock generator. For 
this purpose, the control module CPU3 runs the program code of a slave 
program module designed according to the invention. 



The module MODI transmits its clock signal TS1 via a transmitting module 
SND1 1 on a bus line BUSSND. From the latter, the module MOD2 receives the 
clock signal TS1 with the aid of a receiving module RCV21 and the module 
MOD3 receives it with the aid of a receiving module RCV31 . The module MOD2 
25 then synchronizes its clock generator GEN2 with the clock signal TS1 . The module 
MOD3 also synchronizes with the clock signal TS1 and generates a clock signal 
TS3. However, the clock signals TS2 and TS3 are phase-shifted by the respective 
time intervals that the clock signal TS1 need for the transmission on the bus line 



20 



BUSSND to the modules MOD2 and MOD3. 
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The module MOD2 transmits the clock signal TS2 with the aid of its transmitting 
module SND21 on a bus line BUSRCV for the module MODI , which receives the 
clock signal TS2 with the aid of a receiving module RCV1 1 . The logic component 
5 CP1 forms the correction information CORin a manner known from Figure 1 and 
transmits it with the aid of a transmission module SND1 2 on a bus line CORX to 
the module MOD2. The latter receives the correction information CORwith the aid 
of a receiving module RCV22 and adjusts its clock generator GEN2 

10 The module MOD3 sends the clock signal TS3 with the aid of a transmitting 
module SND31 on the bus line BUSRCV to the module MODI . The logic 
component CP1 forms, in an analogous way as for the module MOD2, an item 
of correction information and transmits it via the transmission module SND1 2 to 
the module MOD3. The latter receives the correction information with the aid of a 

1 5 receiving module RCV32 and adjusts the clock generator function of its control 
module CPU3. 

The receiving module RCV22 of the module MOD2 passes on the correction 
information CORalso to the logic component CP2 so that the latter can, as 
20 explained on the basis of Figure 2, generate, on the one hand, the correction 

value COR2 for the clock generator GEN2 for the purpose of adjusting it and, on 
the other hand, the time difference value DIF2 that a transmitting module SND22 
sends on a bus line DIFX to the module MODI . 

25 The modules in Figure 4 are differently configured to illustrated different design 
variants so that their mode of operation as synchronizing "master module, and 
also as "slave" modules (MOD2 and MOD3) to be synchronized emerges simply 
on the basis of the respective module construction and the respective mode of 
connection of the transmitting and receiving modules. 
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However, it is also possible that similar modules are used that can perform both a 
"slave" function and a "master" function. For example, not only a slave program 
module may be present, as explained, on the module MOD3, but also a master 
5 program module so that the module MOD3 may also act as synchronization 
"master". 

Furthermore, the module MODI may also be constructed like the module MOD3 
and have a processor for running a program code, but may contain, in contrast 
10 to module MOD3, a master program module that can perform the 
synchronization function explained above and, if necessary, also a 
synchronization monitoring function. 

An eligibility to operate as "master module", that is to say an eligibility to 
15 synchronize one or more slave modules, may be permanently stipulated by, for 
example, configuring an interrogation contact, a so-called jumper, on the 
respective module in a suitable way. On the basis of the configuration of the 
jumper, the respective module can determine whether it is being used as master 
module or as slave module. However, provision may also be made that the 
20 respective function is determined dynamically, for example, by that module 

becoming the master module that is the first module to transmit its clock signal. 



